import Vue from 'vue'
// 创建store状态管理
import Vuex from 'vuex'
Vue.use(Vuex)

// 每当初始化项目的时候，就先从localStorage中取一下数据
let car = window.JSON.parse(localStorage.getItem('cart') || '[]')

const store = new Vuex.Store({
    state: {
        // 购物车的数组
        // 在 cart 中，应该把每个商品，存储为一个对象{ id, count, selected, price }
        cart: car,
    },
    mutations: {
        addToCar(state, goods) {
            // 将商品添加到购物车
            // 如果购物车中，之前曾经有这条商品，则只更新数量
            // 如果曾经没有，则直接push
            // state.cart.push(goods)
            let flag = false
            state.cart.some((item, i) => {
                if (item.id == goods.id) {
                    // 如果找到了对应的商品，则直接更新数量
                    item.count += goods.count
                    flag = true
                    // 终止后续循环
                    return true
                }
            })
            if (!flag) {
                state.cart.push(goods)
            }

            // 为了持久化存储购物车的数据，可以把购物车的商品，序列化出来，存储到localStorage中
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },
        updateGoodsCount(state, goods) {
            // 根据传递过来的商品信息，更新购物车中的商品数量
            state.cart.some(item => {
                if (item.id == goods.id) {
                    item.count = goods.count
                    return true
                }

            })
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },
        delFromCart(state, id) {
            // 根据 ID 删除 VUEX 中对应的商品
            state.cart.some((item, i) => {
                if (item.id == id) {
                    state.cart.splice(i, 1)
                    return true
                }
            })
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },
        changeSelectState(state, obj) {
            // 根据提供的obj对象的id和selected属性，更改购物车中商品的选择状态
            state.cart.forEach(item => {
                if (item.id == obj.id) {
                    item.selected = obj.selected
                    return true
                }
                localStorage.setItem('cart', window.JSON.stringify(state.cart))
            })
        }
    },
    getters: {
        totalcount(state) {
            // 徽标中的商品数量
            let c = 0;
            // getters 的特性，只要依赖的数据变化了，必然会重新计算这个 getters 的值
            state.cart.forEach(item => c += item.count)
            return c
        },
        idstr(state) {
            // 获取购物车中所有的商品字符串
            let arr = []
            state.cart.forEach(item => arr.push(item.id))
            return arr.join(',')
        },
        countObj(state) {
            // 获取商品购物车中的ID和商品数量的键值对对应关系
            let o = {}
            state.cart.forEach(item => o[item.id] = item.count)
            return o
            /* {
                88:3,
                89:5
            } */
        },
        selectedObj(state) {
            // ID 对应的商品是否被选中
            let o = {}
            state.cart.forEach(item => o[item.id] = item.selected)
            return o
        },
        selectedCount(state) {
            // 勾选商品的数量
            let c = 0
            state.cart.forEach(item => {
                // 只有这一项商品被选中了，才把数量加起来
                if (item.selected) {
                    c += item.count
                }
            })
            return c
        },
        amount(state) {
            // 总价
            let c = 0
            state.cart.forEach(item => {
                if (item.selected) {
                    c += item.count * item.price
                }
            })
            return c
        }
    }
})

export default store